Animations এবং Transitions এর মাধ্যমে UI Enhancement

Mobile App Development - অ্যান্ড্রয়েড ডেভেলপমেন্ট (Android) - Material Design এবং Custom Views
334

Animations এবং Transitions এর মাধ্যমে UI Enhancement

Animations এবং Transitions Android অ্যাপ্লিকেশনগুলিতে UI উপাদানগুলোর ইন্টারঅ্যাকশন এবং ভিজ্যুয়াল ইফেক্ট উন্নত করতে ব্যবহার করা হয়। এগুলো UI কে আরও আকর্ষণীয় এবং ইন্টারঅ্যাকটিভ করে তোলে, যা ব্যবহারকারীর অভিজ্ঞতাকে উন্নত করতে সহায়ক। Material Design এ অ্যানিমেশন এবং ট্রানজিশন গুরুত্বপূর্ণ ভূমিকা পালন করে, কারণ এটি কন্টেন্ট এবং ইউজারের ইন্টারঅ্যাকশনের মধ্যে একটি সংযোগ তৈরি করে।


Android এ Animations এর ধরন

  1. Property Animations: Property Animations হল Android এর অ্যানিমেশন সিস্টেম, যা ObjectAnimator, ValueAnimator, এবং AnimatorSet ব্যবহার করে UI উপাদানগুলোর প্রপার্টি (যেমন opacity, translation, rotation) পরিবর্তন করে অ্যানিমেশন তৈরি করে।
  2. View Animations: পুরনো অ্যানিমেশন API, যা View এর পরিবর্তন (Scale, Rotate, Translate, Alpha) নির্ধারণ করে।
  3. Drawable Animations: Drawable অ্যানিমেশন ব্যবহার করে একাধিক ইমেজ সিকোয়েন্স তৈরি করা হয়, যা একটি ফ্রেম-বাই-ফ্রেম অ্যানিমেশন তৈরি করে।
  4. MotionLayout: ConstraintLayout এর অংশ, যা Material Design এর সাথে মিল রেখে অ্যানিমেশন পরিচালনা করার জন্য ব্যবহৃত হয়। এটি UI উপাদানগুলোর স্থানান্তর এবং অবস্থান নির্ধারণ করে একটি উন্নত অ্যানিমেশন তৈরি করতে পারে।

Android এ Transitions

Transitions হল একটি Activity বা Fragment থেকে আরেকটিতে যাওয়ার সময় UI উপাদানগুলোর পরিবর্তন। Material Design এ Transitions ব্যবহার করে সহজে Activity এবং Fragment পরিবর্তনের সময় অ্যানিমেশন তৈরি করা যায়।

Transitions এর প্রধান ধরন:

  1. Explode: View উপাদানগুলো স্ক্রিনের কেন্দ্র থেকে বাইরে বা বাইরে থেকে ভিতরে চলে আসে।
  2. Slide: View উপাদানগুলো স্ক্রিনের এক প্রান্ত থেকে অন্য প্রান্তে স্লাইড করে।
  3. Fade: View উপাদানগুলো ধীরে ধীরে দৃশ্যমান বা অদৃশ্য হয়ে যায়।

Example: Property Animation (ObjectAnimator)

Property Animation ব্যবহার করে UI উপাদানগুলোর প্রপার্টি পরিবর্তন করে অ্যানিমেশন তৈরি করা যায়।

activity_main.xml:

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:gravity="center">

    <Button
        android:id="@+id/animateButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Animate"/>

    <ImageView
        android:id="@+id/animatedView"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:src="@drawable/ic_launcher_foreground"/>
</LinearLayout>

MainActivity.java:

import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;
import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    private ImageView animatedView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        animatedView = findViewById(R.id.animatedView);
        findViewById(R.id.animateButton).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ObjectAnimator animator = ObjectAnimator.ofFloat(animatedView, "translationY", 0f, 300f);
                animator.setDuration(500); // ৫০০ মিলিসেকেন্ড সময় নেবে
                animator.start();
            }
        });
    }
}

কোডের ব্যাখ্যা:

  • ObjectAnimator: এটি UI উপাদানের প্রপার্টি (যেমন translationY) এর পরিবর্তন নির্ধারণ করে। setDuration() মেথড দিয়ে অ্যানিমেশনের সময় নির্ধারণ করা হয়েছে।
  • Button: বাটনে ক্লিক করলে অ্যানিমেশন শুরু হয়, যা ImageView কে স্ক্রিনে স্লাইড করে নিয়ে যায়।

Example: Transition Animation

Transition Animation ব্যবহার করে Activity বা Fragment পরিবর্তনের সময় অ্যানিমেশন পরিচালনা করা যায়।

ধাপ ১: Transitions যোগ করা

AndroidManifest.xml এ Activity এর জন্য Transition সেট করা:

<activity android:name=".SecondActivity"
    android:theme="@style/Theme.AppCompat.Light.NoActionBar">
    <meta-data
        android:name="android.support.PARENT_ACTIVITY"
        android:value=".MainActivity" />
</activity>

ধাপ ২: Transition সেটআপ করা

MainActivity.java:

import android.content.Intent;
import android.os.Bundle;
import android.transition.Explode;
import android.transition.Fade;
import android.transition.Slide;
import android.view.View;
import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        findViewById(R.id.transitionButton).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // নতুন Activity তে যাওয়ার জন্য Intent
                Intent intent = new Intent(MainActivity.this, SecondActivity.class);

                // Transition সেট করা
                getWindow().setExitTransition(new Slide());
                startActivity(intent, null);
            }
        });
    }
}

ধাপ ৩: SecondActivity এ Transition যোগ করা

SecondActivity.java:

import android.os.Bundle;
import android.transition.Fade;
import androidx.appcompat.app.AppCompatActivity;

public class SecondActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_second);

        // Transition সেট করা
        getWindow().setEnterTransition(new Fade());
    }
}

কোডের ব্যাখ্যা:

  • Slide() এবং Fade(): Transition এর ধরন। Slide Transition এ UI উপাদান স্ক্রিনে স্লাইড করে, এবং Fade Transition এ UI উপাদান ধীরে ধীরে দৃশ্যমান বা অদৃশ্য হয়।
  • getWindow().setExitTransition() এবং getWindow().setEnterTransition(): Activity এর জন্য Exit এবং Enter Transition সেট করা হয়েছে।

MotionLayout ব্যবহার করে Advanced Animation

MotionLayout হল ConstraintLayout এর উপর ভিত্তি করে তৈরি একটি লেআউট, যা UI উপাদানগুলোর অ্যানিমেশন এবং স্থানান্তর ম্যানেজ করতে সাহায্য করে। এটি Material Design এর সাথে সামঞ্জস্য রেখে অ্যানিমেশন তৈরি করার জন্য ব্যবহৃত হয়।

MotionLayout উদাহরণ:

  1. MotionLayout এর XML তৈরি:
<androidx.constraintlayout.motion.widget.MotionLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/motionLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="100dp"
        android:layout_height="100dp"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintStart_toStartOf="parent"/>

</androidx.constraintlayout.motion.widget.MotionLayout>
  1. MotionScene ফাইল তৈরি:
<MotionScene xmlns:android="http://schemas.android.com/apk/res/android">
    <Transition
        app:constraintSetStart="@id/start"
        app:constraintSetEnd="@id/end"
        app:duration="1000">
        <OnSwipe
            app:dragDirection="dragUp"
            app:touchAnchorId="@id/imageView"
            app:touchAnchorSide="bottom"/>
    </Transition>

    <ConstraintSet android:id="@+id/start">
        <Constraint
            android:id="@id/imageView"
            app:layout_constraintTop_toTopOf="parent"/>
    </ConstraintSet>

    <ConstraintSet android:id="@+id/end">
        <Constraint
            android:id="@id/imageView"
            app:layout_constraintBottom_toBottomOf="parent"/>
    </ConstraintSet>
</MotionScene>

উপসংহার

Android অ্যাপ্লিকেশনে Animations এবং Transitions ব্যবহার করে UI কে আরও ইন্টারঅ্যাকটিভ এবং ব্যবহারবান্ধব করা যায়। এগুলো ব্যবহারকারীর ইন্টারফেস এবং অ্যাপ্লিকেশনের কার্যকারিতা উন্নত করতে সাহায্য করে। Material Design এর নীতিমালা অনুসরণ করে অ্যানিমেশন এবং ট্রানজিশন তৈরি করলে, ব্যবহারকারীর অভিজ্ঞতা আরও উন্নত এবং আকর্ষণীয় হয়।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...